# Chương 2: Họ vi điều khiển 8051 (tổ chức bộ nhớ)





### Mục tiêu



- Hiểu được cấu trúc bộ nhớ bên trong văk 8051
- Biết được cách hoạt động các thanh ghi đặt biệt
- Biết được cách ghép nối với ROM, RAM ngoài
- □ Biết được các kiểu định địa chỉ trong 8051



### Nội dung



- □ Tổ chức bộ nhớ
- Các chế độ định địa chỉ

COMPUTER ENGINEERING



### Ôn tập chương 2-1



- □ Nêu các thành phần bên trong của họ vđk 8051?
- □ Nêu 1 số đặt trưng của họ vđk 8051?
- □ Nêu chức năng các port của 8051?
- □ EA, ALE, PSEN có tác dụng gì?
- Có mấy loại tạo clock ngoài cho 8051, nêu cụ thể?

COMPUTER ENGINEERING



### Tổ chức bộ nhớ 8051



Bộ nhớ trong

ROM 4KB 0000h – 0FFFh

RAM 128 byte 00h – 7Fh

> SFR 80h – 0FFh

Bộ nhớ ngoài

Bộ nhớ chương trình 64 KB 0000h – FFFFh Điều khiển bằng PSEN

Bộ nhớ dữ liệu 64 KB 0000h – FFFFh Điều khiển bằng RD và WR



### Cấu trúc RAM nội trong 8051



| 0xFF<br>0x80 | Upper 128 RAM<br>(Indirect Addressing<br>Only) | Special Function<br>Register's<br>(Direct Addressing Only) |
|--------------|------------------------------------------------|------------------------------------------------------------|
| 0x7F<br>0x30 | (Direct and Indirect<br>Addressing)            | Lower 128 RAM<br>(Direct and Indirect                      |
| 0x2F<br>0x20 | Bit Addressable                                | Addressing)                                                |
| 0x1F<br>0x00 | General Purpose<br>Registers                   |                                                            |



### Các bank thanh ghi







### Các bank thanh ghi



|    | Bank 0 |    | Bank 1 |    | Bank 2 |    | Bank 3 |
|----|--------|----|--------|----|--------|----|--------|
| 07 | R7     | 0F | R7     | 17 | R7     | 1F | R7     |
| 06 | R6     | 0E | R6     | 16 | R6     | 1E | R6     |
| 05 | R5     | 0D | R5     | 15 | R5     | 1D | R5     |
| 04 | R4     | 0C | R4     | 14 | R4     | 1C | R4     |
| 03 | R3     | 0B | R3     | 13 | R3     | 1B | R3     |
| 02 | R2     | 0A | R2     | 12 | R2     | 1A | R2     |
| 01 | R1     | 09 | R1     | 11 | R1     | 19 | R1     |
| 0  | R0     | 08 | R0     | 10 | R0     | 18 | R0     |
|    |        |    |        |    |        |    |        |

| RS1 | RS0 | Register Bank | Address |  |
|-----|-----|---------------|---------|--|
| 0   | 0   | 0             | 00H-07H |  |
| 0   | 1   | 1             | 08H-0FH |  |
| 1   | 0   | 2             | 10H-17H |  |
| 1   | 1   | 3             | 18H-1FH |  |



### Bank 1 được sử dụng làm stack





MOV R6,#25H MOV R1,#12H MOV R4,#0F3H PUSH 6 PUSH 1 PUSH 4





### Các thanh ghi định địa chỉ bit





20h – 2Fh (16 locations X 8bits = 128 bits)

Bit addressing: mov C, 1Ah or

mov C, 23h.2





### Tổng kết vùng RAM thấp



| Địa chỉ byte | Địa chỉ bit |         |       |         |         |        |     |    | Chức năng                                                                |  |  |  |  |  |
|--------------|-------------|---------|-------|---------|---------|--------|-----|----|--------------------------------------------------------------------------|--|--|--|--|--|
| 7F           |             |         |       |         |         |        |     |    |                                                                          |  |  |  |  |  |
| 30           |             |         |       |         |         |        |     |    | Vùng RAM đa dụng                                                         |  |  |  |  |  |
| 2F           | 7F          | 7E      | 7D    | 7C      | 7B      | 7A     | 79  | 78 |                                                                          |  |  |  |  |  |
| 2E           | 77          | 76      | 75    | 74      | 73      | 72     | 71  | 70 |                                                                          |  |  |  |  |  |
| 2D           | 6F          | 6E      | 6D    | 6C      | 6B      | 6A     | 69  | 68 |                                                                          |  |  |  |  |  |
| 2C           | 67          | 66      | 65    | 64      | 63      | 62     | 61  | 60 |                                                                          |  |  |  |  |  |
| 2B           | 5F          | 5E      | 5D    | 5C      | 5B      | 5A     | 59  | 58 |                                                                          |  |  |  |  |  |
| 2A           | 57          | 56      | 55    | 54      | 53      | 52     | 51  | 50 |                                                                          |  |  |  |  |  |
| 29           | 4F          | 4E      | 4D    | 4C      | 4B      | 4A     | 49  | 48 |                                                                          |  |  |  |  |  |
| 28           | 47          | 46      | 45    | 44      | 43      | 42     | 41  | 40 | Mana a fala de dina de dina de de la |  |  |  |  |  |
| 27           | 3F          | 3E      | 3D    | 3C      | 3B      | 3A     | 39  | 38 | Vùng có thể định địa chỉ bit                                             |  |  |  |  |  |
| 26           | 37          | 36      | 35    | 34      | 33      | 32     | 31  | 30 | 1                                                                        |  |  |  |  |  |
| 25           | 2F          | 2E      | 2D    | 2C      | 2B      | 2A     | 29  | 28 |                                                                          |  |  |  |  |  |
| 24           | 27          | 26      | 25    | 24      | 23      | 22     | 21  | 20 |                                                                          |  |  |  |  |  |
| 23           | 1F          | 1E      | 1D    | 1C      | 1B      | 1A     | 19  | 18 |                                                                          |  |  |  |  |  |
| 22           | 17          | 16      | 15    | 14      | 13      | 12     | 11  | 10 |                                                                          |  |  |  |  |  |
| 21           | 0F          | 0E      | 0D    | 0C      | 0B      | 0A     | 09  | 08 |                                                                          |  |  |  |  |  |
| 20           | 07          | 06      | 05    | 04      | 03      | 02     | 01  | 00 |                                                                          |  |  |  |  |  |
| 1F           |             |         |       | Baı     | nk 3    |        |     |    |                                                                          |  |  |  |  |  |
| 18           |             |         |       | Dai     | iik 5   |        |     |    |                                                                          |  |  |  |  |  |
| 17           | Bank 2      |         |       |         |         |        |     |    | 67 1 1 1 1 1                                                             |  |  |  |  |  |
| 10           | Dailk 2     |         |       |         |         |        |     |    | Các bank thanh ghi                                                       |  |  |  |  |  |
| 1F           |             |         |       | Bai     | nk 1    |        |     |    |                                                                          |  |  |  |  |  |
| 08           |             |         |       | Dui     |         |        |     |    |                                                                          |  |  |  |  |  |
| 07           | Banl        | c thanh | ghi 0 | ( mặc đ | tinh ch | o R0-R | 27) |    |                                                                          |  |  |  |  |  |
| 00           |             |         | 3     | (       | ,       |        |     |    |                                                                          |  |  |  |  |  |



### Cấu trúc RAM nội trong 8051



## Special Function Registers

- Thanh ghi DATA
- □ Thanh ghi CONTROL
  - □ Timer
  - Serial ports
  - Interrupt system
  - ADC
  - DAC
  - □ ...



Addresses 80h - FFh

Direct Addressing used to access SFRs



# Các thanh ghi có chức năng đặt biệt cdio



| Địa<br>chỉ<br>byte | Có thể<br>định địa<br>chỉ bit | Không định địa<br>chỉ bit |          |          |       |       |      |       |  |
|--------------------|-------------------------------|---------------------------|----------|----------|-------|-------|------|-------|--|
| F8h                |                               |                           |          |          |       |       |      |       |  |
| F0h                | В                             |                           |          |          |       |       |      |       |  |
| E8h                |                               |                           |          |          |       |       |      |       |  |
| E0h                | ACC                           |                           |          |          |       |       |      |       |  |
| D8h                |                               |                           |          |          |       |       |      |       |  |
| D0h                | PSW                           |                           |          |          |       |       |      |       |  |
| C8h                | (T2CON)                       |                           | (RCAP2L) | (RCAP2H) | (TL2) | (TH2) |      |       |  |
| C0h                |                               |                           |          |          |       |       |      |       |  |
| B8h                | IP                            | SADEN                     |          |          |       |       |      |       |  |
| B0h                | Р3                            |                           |          |          |       |       |      |       |  |
| A8h                | IE                            | SADDR                     |          |          |       |       |      |       |  |
| A0h                | P2                            |                           |          |          |       |       |      |       |  |
| 98h                | SCON                          | SBUF                      | BRL      | BDRCON   |       |       |      |       |  |
| 90h                | P1                            |                           |          |          |       |       |      |       |  |
| 88h                | TCON                          | TMOD                      | TL0      | TH0      | TL1   | TH1   | AUXR | CKCON |  |
| 80h                | P0                            | SP                        | DPL      | DPH      |       |       |      | PCON  |  |

Họ vi điều khiển 8051 **Duy Phan** 13



### Các thanh ghi có chức năng đặt biệt cdio



90C51 Special Function Posictors

| Table 1. | . 80C51 Special Function Registers |                   |        |        |          |          |        |         |         |            |             |
|----------|------------------------------------|-------------------|--------|--------|----------|----------|--------|---------|---------|------------|-------------|
| SYMBOL   | DESCRIPTION                        | DIRECT<br>ADDRESS | BIT AD | DRESS, | SYMBO    | L, OR AL | TERNAT | IVE POR | T FUNCT | ION<br>LSB | RESET VALUE |
| ACC*     | Accumulator                        | E0H               | E7     | E6     | E5       | E4       | E3     | E2      | E1      | E0         | 00H         |
| B*       | B register                         | F0H               | F7     | F6     | F5       | F4       | F3     | F2      | F1      | FO         | 00H         |
| DPTR     | Data pointer (2 by-<br>tes)        |                   |        |        |          |          |        |         |         |            |             |
| DPH      | Data pointer high                  | 83H               |        |        |          |          |        |         |         |            | 00H         |
| DPL      | Data pointer low                   | 82H               |        |        |          |          |        |         |         |            | 00H         |
|          |                                    |                   | AF     | AE     | AD       | AC       | AB     | AA      | A9      | A8         |             |
| IE*      | Interrupt enable                   | A8H               | EA     | -      | -        | ES       | ET1    | EX1     | ET0     | EX0        | 0x000000B   |
|          |                                    |                   | BF     | BE     | BD       | BC       | BB     | BA      | В9      | B8         |             |
| IP*      | Interrupt priority                 | B8H               | -      | -      | -        | PS       | PT1    | PX1     | PT0     | PX0        | xx000000B   |
|          |                                    |                   | 87     | 86     | 85       | 84       | 83     | 82      | 81      | 80         |             |
| P0*      | Port 0                             | 80H               | AD7    | AD6    | AD5      | AD4      | AD3    | AD2     | AD1     | AD0        | FFH         |
|          |                                    |                   |        |        |          | •        |        |         |         |            | 1           |
|          |                                    |                   | 97     | 96     | 95       | 94       | 93     | 92      | 91      | 90         |             |
| P1*      | Port 1                             | 90H               | _      | -      | -        | -        | -      | -       | T2EX    | T2         | FFH         |
|          |                                    |                   |        |        |          |          |        |         |         |            | 1           |
|          |                                    |                   | A7     | A6     | A5       | A4       | АЗ     | A2      | A1      | A0         |             |
| P2*      | Port 2                             | A0H               | A15    | A14    | A13      | A12      | A11    | A10     | A9      | A8         | FFH         |
|          |                                    |                   | B7     | В6     | B5       | B4       | В3     | B2      | B1      | В0         |             |
| P3*      | Port 3                             | вон               | RD     | WR     | T1       | T0       | INT1   | INTO    | TxD     | Rxd        | FFH         |
| PCON1    | Power control                      | 87H               | SMOD   | -      | -        | -        | GF1    | GF0     | PD      | IDL        | 0xxxxxxxB   |
|          |                                    |                   |        |        | <b>.</b> | •        |        |         |         |            | 1           |
|          |                                    |                   | D7     | D6     | D5       | D4       | D3     | D2      | D1      | D0         |             |
| PSW*     | Program status word                | D0H               | CY     | AC     | F0       | RS1      | RS0    | OV      | -       | Р          | 00H         |
| SBUF     | Serial data buffer                 | 99H               |        |        | •        | •        |        |         |         | •          | xxxxxxxxB   |
|          |                                    |                   | 9F     | 9E     | 9D       | 9C       | 9B     | 9A      | 99      | 98         |             |
| SCON*    | Serial controller                  | 98H               | SM0    | SM1    | SM2      | REN      | TB8    | RB8     | TI      | RI         | 00H         |
| SP       | Stack pointer                      | 81H               |        |        | •        |          |        |         |         |            | 07H         |
|          |                                    |                   | 8F     | 8E     | 8D       | 8C       | 8B     | 8A      | 89      | 88         |             |
| TCON*    | Timer control                      | 88H               | TF1    | TR1    | TF0      | TR0      | IE1    | IT1     | IE0     | IT0        |             |
| TH0      | Timer high 0                       | 8CH               |        |        |          |          |        |         |         |            | 00H         |
| TH1      | Timer high 1                       | 8DH               |        |        |          |          |        |         |         |            | 00H         |
| TLO      | Timer low 0                        | 8AH               |        |        |          |          |        |         |         |            | 00H         |
| TL1      | Timer low 1                        | 8BH               |        |        |          |          |        |         |         |            | 00H         |
| TMOD     | Timer mode                         | 89H               | GATE   | C/T    | M1       | MO       | GATE   | C/T     | M1      | M0         | 00H         |



### Các thanh ghi CPU 8051





- □ A: Thanh ghi tích lũy
- □ B: Dùng trong nhân/chia
- □ PSW: Trang thái chương

trình

- ☐ SP: Stack Pointer
- □ PC: Program Counter
- DPTR: Data PoinTeR

| DPTR | DPH    | DPL |  |  |  |
|------|--------|-----|--|--|--|
| PC   | EEDING | С   |  |  |  |

Thanh ghi 16-bit trong 8051



### Thanh ghi PSW



#### PSW: PROGRAM STATUS WORD. BIT ADDRESSABLE.

| CY  | AC    | F0         | RS1                                               | RS0                | ov          | <u> </u>    | Р        |     |  |  |  |  |
|-----|-------|------------|---------------------------------------------------|--------------------|-------------|-------------|----------|-----|--|--|--|--|
| CY  | PSW.7 | Carry Fla  | ıg.                                               |                    |             |             |          |     |  |  |  |  |
| AC  | PSW.6 | Auxiliary  | Auxiliary Carry Flag.                             |                    |             |             |          |     |  |  |  |  |
| F0  | PSW.5 | Flag 0 av  | Flag 0 available to the user for general purpose. |                    |             |             |          |     |  |  |  |  |
| RS1 | PSW.4 | Register 1 | Register Bank selector bit 1 (SEE NOTE 1).        |                    |             |             |          |     |  |  |  |  |
| RS0 | PSW.3 | Register 1 | Register Bank selector bit 0 (SEE NOTE 1).        |                    |             |             |          |     |  |  |  |  |
| ov  | PSW.2 | Overflow   | Overflow Flag.                                    |                    |             |             |          |     |  |  |  |  |
| _   | PSW.1 | User defin | User definable flag.                              |                    |             |             |          |     |  |  |  |  |
| P   | PSW.0 |            | g. Set/cleare<br>the accum                        | ed by hardwalator. | are each in | struction ( | cycle to | o i |  |  |  |  |

#### NOTE:

1. The value presented by RS0 and RS1 selects the corresponding register bank.

| RS1 | RS0 | Register Bank | Address |
|-----|-----|---------------|---------|
| 0   | 0   | 0             | 00H-07H |
| 0   | 1   | 1 [           | 08H-0FH |
| 1   | 0   | 2             | 10H-17H |
| 1   | 1   | 3             | 18H-1FH |





#### Use external memory - Address multiplexing







Timing diagram for external CODE memory access



Note: PCH = Program counter high byte

PCL = Program counter low byte























### Mở rộng bộ nhớ dữ liệu (1K bytes)







### Các chế độ định địa chỉ



- Dia chỉ tức thời
- Dia chỉ theo thanh ghi
- Dia chi trực tiếp
- Địa chỉ gián tiếp
- Dịa chỉ chỉ số



### Địa chỉ tức thời



- □ Toán hạng nguồn là một hằng số (có dấu # phía trước)
- Dùng để nạp thông tin vào bất kỳ thanh ghi nào



### Địa chỉ tức thời (tt)



- □ Toán hạng nguồn là một hằng số (có dấu # phía trước)
- Dùng để nạp thông tin vào bất kỳ thanh ghi nào

```
MOV DPTR,#7521h
MOV DPL,#21H
MOV DPH, #75H
COUNT EGU 30
```

mov R4, #COUNT MOV DPTR,#MYDATA

ORG 200H MYDATA:DB "IRAN"



### Địa chỉ theo thanh ghi



- Sử dụng các thanh ghi để lưu dữ liệu cần được thao tác
- □ Các toán hạng là 1 trong các thanh ghi Ri (i =0-7)

MOV RO,A

MOV A,R7

ADD A,R4

ADD A,R7

MOV DPTR,#25F5H

MOV R5,DPLER ENGINEERING

Note that MOV R4,R7 is incorrect



### Địa chỉ trực tiếp



Toán hạng là tên hoặc địa chỉ của các thanh ghi trong vùng RAM thấp và SFR

Mov a, 70h; copy contents of RAM at 70h to a

Mov RO,40h; copy contents of RAM at 70h to a

Mov 56h,a; put contents of a at 56h to a

Mov ODOh,a; put contents of a into PSW

#### DATA MEMORY (RAM) INTERNAL DATA ADDRESS SPACE





### Địa chỉ trực tiếp



Toán hạng là tên hoặc địa chỉ của các thanh ghi trong vùng RAM thấp và SFR

MOV A,4 = MOV A,R4

MOVA,7 = MOVA,R7

MOV7,2 = MOVR7,R6

MOV A,#5 ;Put 5 in A

MOV A,5 ; Put content of RAM at 5 in A



### Địa chỉ gián tiếp



- Một thanh ghi được sử dụng như một con trỏ dữ liệu
- Toán hạng nằm trong toàn bộ RAM thấp, cao, ngoài; và không dung cho SFR; có ký tự @ trước toán hạng
- Địa chỉ của toán hạng chứa trong thanh ghi con trỏ RO, R1, DPTR)

```
mov psw, #0
```

mov r0, #0x3C

mov @r0, #3

; use register bank 0

; memory at 3C gets #3

;  $M[3C] \leftarrow 3$ 



PC

### Địa chỉ chỉ số



- Dùng trong không gian ROM/RAM chương trình trong dải 64KB
- Thanh ghi DPTR/PC và thanh ghi A được dùng để tạo ra địa chỉ của phần dữ liệu được lưu trong bộ nhớ

```
mov dptr, #4000h
mov a, #5
movc a, @a + dptr ;a ← M[4005]

ORG 1000h
1000 mov a, #5R ENGINEERING
1002 movc a, @a + PC ;a ← M[1008]

→1003 Nop
```



### **Ô**n tập



- □ Cấu trúc bên trong RAM
- □ Các bank thanh ghi, stack
- Các thanh ghi chức năng đặt biệt
- □ Kết nối ROM, RAM ngoài
- □ Các kiểu định địa chỉ

#### COMPUTER ENGINEERING

# Kết thúc chương 2-2



09/2015